// app/api/projects/[projectId]/access/route.ts import { NextRequest, NextResponse } from 'next/server'; import { getServerSession } from 'next-auth/next'; import { authOptions } from '@/app/api/auth/[...nextauth]/route' import { ProjectService } from '@/lib/services/projectService'; // 프로젝트 접근 권한 확인 export async function GET( request: NextRequest, { params }: { params: { projectId: string } } ) { try { const session = await getServerSession(authOptions); if (!session?.user) { return NextResponse.json({ error: '인증이 필요합니다' }, { status: 401 }); } const projectService = new ProjectService(); const access = await projectService.checkProjectAccess( params.projectId, Number(session.user.id) ); return NextResponse.json({ hasAccess: access.hasAccess, role: access.role || 'viewer', isOwner: access.isOwner, }); } catch (error) { console.error('권한 확인 오류:', error); return NextResponse.json( { hasAccess: false, role: 'viewer', isOwner: false }, { status: 500 } ); } }